#!/bin/bash

#set -x

# defaults
MPIRUN="mpirun"
MPIRUNEXECPARM=""

# include definitions
. ./mpirun.defs

TESTNAME=omp____1
rm -rf run_test_${TESTNAME}
if (! [ -d run_test_${TESTNAME} ] ) 
then
    mkdir run_test_${TESTNAME}
fi

SIONDUMP=../siondump

(

  cd run_test_${TESTNAME}
  




  
  export LSION_DEBUG=test_${TESTNAME}
  export LSION_DEBUG_MASK=1023
  export LSION_DEBUG_RANK1=0
  export LSION_DEBUG_RANK2=3
  export LSION_ERROR_MSG_RANK=0
  export LSION_DEBUG_SILENT=1


  export OMP_NUM_THREADS=4

  MYMPIRUN=`echo ${MPIRUN} | sed 's/-np 4/-np 1/g'| sed 's/-n 4/-n 1/g'`
  MYMPIRUNEXECPARM=`echo ${MPIRUNEXECPARM} | sed 's/-np 4/-np 1/g'| sed 's/-n 4/-n 1/g'`
  if [ "${COVERAGE}" = "kcov" ] && type kcov 2>&1 > /dev/null
  then
      ${MYMPIRUN} sh -c "kcov --include-pattern=sion_ kcov_output_\$\$ ../test_${TESTNAME}" ${MYMPIRUNEXECPARM} 1> stdout.log 2> stderr.log
      kcov --merge kcov_output kcov_output_* 2>&1 > /dev/null
  else
      ${MYMPIRUN} ../test_${TESTNAME} ${MYMPIRUNEXECPARM} 1> stdout.log 2> stderr.log
  fi

  grep 'on OMP thread 0' stdout.log  | grep -v 'Writing debug output' | grep -v 'sid           =' > stdout_0.log
  grep 'on OMP thread 0' stderr.log > stderr_0.log

  export LSION_DEBUG=siondump_${TESTNAME}

  ${SIONDUMP} -a -m -l testB.out 1>> stdout_siondump.log 2>> stderr_siondump.log

  cat stdout_siondump.log | grep -v 'endianness' | grep -v 'SIONlib version' | grep -v 'Writing debug output' >> stdout_0.log
  cat stderr_siondump.log | grep -v 'Writing debug output' >> stdout_0.log

  if diff stderr_0.log ../test_${TESTNAME}_stderr_0.log > /dev/null
  then
      if diff stdout_0.log ../test_${TESTNAME}_stdout_0.log > /dev/null
      then
	  echo "     test_${TESTNAME}              ... OK"
      else
	  echo "     test_${TESTNAME}              ... FAILED (diff in stdout)"
	  diff -u stdout_0.log ../test_${TESTNAME}_stdout_0.log
      fi
  else
      echo "     test_${TESTNAME}              ... FAILED (diff in stderr)"
      diff -u stderr_0.log ../test_${TESTNAME}_stderr_0.log
  fi

)
